- 
                Notifications
    You must be signed in to change notification settings 
- Fork 6.6k
Update requirements.txt #13557
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update requirements.txt #13557
Conversation
Fix incorrect Python libraries
| No region tags are edited in this PR.This comment is generated by snippet-bot. 
 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Summary of Changes
Hello @adammil2000, I'm Gemini Code Assist1! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed!
This pull request updates the Python dependencies for the functions/billing module by modifying its requirements.txt file. The change ensures that the function relies on the correct and modern set of libraries, specifically for cloud event handling, function execution, and Google Cloud billing and logging services, thereby improving the function's operational integrity and alignment with current best practices.
Highlights
- Dependency Correction: The pull request addresses and fixes incorrect Python library dependencies for a specific function.
- Library Update: It updates the requirements.txtfile for thefunctions/billingmodule, replacing outdated or irrelevant libraries with current and necessary ones.
- Specific Libraries Changed: slackclientandgoogle-api-python-clientare removed, andcloudevents,functions-framework,google-cloud-billing, andgoogle-cloud-loggingare added with specified versions.
Using Gemini Code Assist
The full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips.
Invoking Gemini
You can request assistance from Gemini at any point in your pull request via creating an issue comment (i.e. comment on the pull request page) using either /gemini <command> or @gemini-code-assist <command>. Below is a summary of the supported commands.
| Feature | Command | Description | 
|---|---|---|
| Code Review | /gemini review | Performs a code review for the current pull request in its current state. | 
| Pull Request Summary | /gemini summary | Provides a summary of the current pull request in its current state. | 
| Comment | @gemini-code-assist | Responds in comments when explicitly tagged, both in issue comments and review comments. | 
| Help | /gemini help | Displays a list of available commands. | 
Customization
To customize Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a .gemini/ folder in the base of the repository. Detailed instructions can be found here.
Limitations & Feedback
Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counter productive. You can react with 👍 and 👎 on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for Github and other Google products, sign up here.
You can also get AI-powered code generation, chat, as well as code reviews directly in the IDE at no cost with the Gemini Code Assist IDE Extension.
Footnotes
- 
Review the Privacy Notices, Generative AI Prohibited Use Policy, Terms of Service, and learn how to configure Gemini Code Assist in GitHub here. Gemini can make mistakes, so double check it and use code with caution. ↩ 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Code Review
This pull request updates the requirements.txt file, replacing the existing Python libraries with a new set of dependencies. However, these new libraries are incompatible with the current implementation in main.py, which will cause ImportError exceptions and break the function. A critical review comment has been added to highlight this issue, suggesting either reverting the changes or including the necessary code modifications in main.py to use the new dependencies.
| cloudevents==1.10.1 | ||
| functions-framework==3.5.0 | ||
| google-cloud-billing==1.18.1 | ||
| google-cloud-logging==3.9.0 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The updated dependencies are inconsistent with the imports in main.py. The existing code imports googleapiclient and slack, which are provided by google-api-python-client and slackclient respectively. These dependencies have been removed, which will cause ImportError exceptions and break the function.
The newly added dependencies (cloudevents, functions-framework, google-cloud-billing, google-cloud-logging) are not used in main.py.
Additionally, the region tags (# [START ...] and # [END ...]) have been removed. These are often important for documentation generation and code samples.
If the goal is to migrate to newer client libraries, the code in main.py must be updated as part of this PR. Otherwise, the previous dependencies should be restored to ensure the function remains operational.
slackclient==2.9.4
# [START functions_billing_limit_appengine_deps]
google-api-python-client==2.131.0
# [END functions_billing_limit_appengine_deps]
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@adammil2000 thanks for your contribution but this isn't going to work as expected as gemini-code-assist is sharing. What are you trying to fix?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with @iennae. The changes in requirements.txt appear to be incompatible with the existing main.py file. Could you please clarify the intended purpose of this pull request, @adammil2000? Understanding the goal will help determine the correct set of dependencies and necessary code changes.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In this doc page:
we had a report from one of the devs that the libraries indicated on this page are missing these required ones (updated to use wildcards):
cloudevents==1.10.1
google-cloud-billing==1.*
google-cloud-logging==3.*
I suspect we don't need the slack dependency either.
But I am unfamiliar with the process to get these github repo samples updated so they reflect correctly in the docs. Also I don't see main.py discussed on this doc page, so that threw me a bit about what to do with that one.
Thanks!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@adammil2000 Got it! Apologies for the delay. I think the problem is you want to pull this requirements file https://github.com/GoogleCloudPlatform/python-docs-samples/blob/e6d1b6c547ee4c9c115be05acc61d8f55a0b2a3c/functions/billing_stop_on_notification/requirements.txt for the documentation and not this one.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Replaced missing dependency block and fixed typo for billing to 1.16.1
| cloudevents==1.10.1 | ||
| functions-framework==3.5.0 | ||
| google-cloud-billing==1.18.1 | ||
| google-cloud-logging==3.9.0 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In this doc page:
we had a report from one of the devs that the libraries indicated on this page are missing these required ones (updated to use wildcards):
cloudevents==1.10.1
google-cloud-billing==1.*
google-cloud-logging==3.*
I suspect we don't need the slack dependency either.
But I am unfamiliar with the process to get these github repo samples updated so they reflect correctly in the docs. Also I don't see main.py discussed on this doc page, so that threw me a bit about what to do with that one.
Thanks!
| @adammil2000 thanks for the details. I've gone ahead and made a new region tag and opened a PR here #13610 Please update your source documents with functions_billing_stop_requirements | 
Fix incorrect Python libraries
Description
Fixes #
Note: Before submitting a pull request, please open an issue for discussion if you are not associated with Google.
Checklist
nox -s py-3.9(see Test Environment Setup)nox -s lint(see Test Environment Setup)